

INTERFACE, STRUCTURE AND METHOD FOR  
TRANSMITTING DATA OF PCI BUS

5

CROSS-REFERENCE TO RELATED APPLICATION

This application is a continuation-in-part of prior applications Serial No. 09/447,724, filed November 24, 1999. This application also claims the priority benefit of U.S.A. provisional application serial no. 60/215,565, filed on June 30, 2000, and Taiwan application serial no. 90113548, filed on June 5, 2001.

10

BACKGROUND OF THE INVENTION

Field of the Invention

[0001] The invention relates in general to a PCI bus compatible structure, and more particularly, to a PCI bus structure that supports multiple transmission speeds.

15 Description of the Related Art

[0002] Figure 1 shows a structure using a PCI system in a normal computer. The central processing unit (CPU) 10 is coupled to the PCI bus 14 via the host bridge 12. The PCI bus 14 can be coupled to multiple masters 16a, 16b, 16c and 16d of PCI compatible peripherals. Each master can send a request signal (REQ) to require using 20 the PCI bus 14. The arbiter in the host bridge 12 then sends the grant signal (GNT) to the master to grant the usage of the PCI bus 14.

[0003] The data transmission between the PCI compatible peripherals (such as the masters or the north bridge of the computer chip set) is controlled by the following interface control signals. The cycle frame signal FRAME# is asserted by an initiator

(such as the masters or the north bridge) to confirm whether the transmission data is the last batch of data. When the cycle frame signal FRAME# is output, it indicates that the transaction of the data transmission via the PCI bus is started. As long as the cycle frame signal FRAME# remains in a low potential, the transaction of the data  
5 transmission continues. Meanwhile, the AD (data address signal) bus outputs a valid address during the address cycle and outputs a valid bus command during command/byte enable (CBE[3:0]) to indicate the data transaction type required by the initiator to a target. Right after all the valid addresses are output, the AD bus outputs the data to be transmitted, which is called the data cycle. Meanwhile, the byte enable  
10 signal of bus command after coding is output from the CBE line to transmit data. Cessation of output of the cycle frame signal FRAME# means the transaction status is transmitting the last batch of data, or the data transmission is complete. The initiator ready signal IRDY# and the target ready signal TRDY# are used to respectively indicate that the initiator and the target are ready to perform data transmission. In a read  
15 operation, the IRDY# signal means that the initiator is ready to receive data. When entering a write operation, the TRDY# signal indicates that the target is ready to receive data. The stop signal STOP# is used to indicate the target to request the initiator stopping the current transaction of data transmission.

[0004] However, during transmission, all the signals are transmitted according to  
20 the 33 MHz bus clock, and are triggered according to the rising edge of the clock. Thus, the data signal in one clock cycle can only transmit a set of data. Therefore, the data transmission speed is restricted by the bus clock and cannot cope with the requirements of high speed of data transmission.

## SUMMARY OF THE INVENTION

[0005] The invention provides a bus data interface, structure and method to transmit data in a PCI bus. The pins of the bus request signal and bus grant signal are used to transmit a data strobe signal. The high potential and the low potential of the data strobe signal are used as a reference for transmission. Thus, the invention is compatible with the original PCI bus. A transmission operation having two times the original transmission clock is obtained to increase the overall data transmission speed.

[0006] The bus data interface to transmit the data of the PCI bus is applied to an apparatus compatible with the PCI bus. The PCI bus comprises at least a bus grant signal and a bus grant signal. The bus data interface comprises at least a high-bit transmitting buffer, a low-bit transmitting buffer, a multiplexer, a strobe generator and a data distributor.

[0007] The above high-bit transmitting buffer is used to receive and temporarily store high-bit transmitting data, while the low-bit transmitting buffer is used to receive and temporarily stores low-bit transmitting data. The multiplexer is coupled to the high-bit and the low-bit transmitting buffers to receive an internal bus clock signal of the bus data interface. When the internal bus clock signal is at a high potential, the multiplexer selects and outputs either the high-bit transmitting data or the low-bit transmitting data to the PCI bus. The multiplexer then selects and outputs the other of the high-bit transmitting data and the low-bit transmitting data to the PCI bus.

[0008] The strobe generator uses either the bus grant signal or the bus request signal to generate a data strobe signal. Correspondingly, the data distributor uses either the bus grant signal or the bus request signal to receive the data strobe signal. When the bus data interface outputs data to the PCI bus, the strobe generator outputs the data

strobe signal in response to the internal bus clock signal. The data distributor coupled to the PCI bus receives data from the PCI bus according to the received data strobe signal, and transfers the high-bit and the low-bit data respectively.

[0009] In one embodiment, the bus data interface to transmit data on the PCI bus  
5 shows that when the bus master supporting the dual transmission mode is writing data,  
that is, outputting data to the PCI bus, the bus request signal pin is used as the data  
transmitting strobe signal pin. When the bus master is reading data, that is, the PCI bus  
is receiving data, the bus grant signal pin is used as the data receiving strobe signal  
pin. When applying the bus data interface to a bus bridge that arbitrates the master  
control of the PCI bus according to the bus request and grant signals, and when the bus  
bridge is outputting data to the PCI bus, the bus grant signal pin is the strobe signal pin  
for data transmission. Similarly, the bus request pin is the strobe signal pin for data  
receiving when the bus bridge is receiving data from the PCI bus.  
10

[0010] The invention provides another embodiment for the bus structure for  
15 transmitting data on the PCI bus. The bus grant signal pin and the bus request signal pin  
are used in the invention. The bus structure comprises at least a transmission  
compatible apparatus and reception compatible apparatus coupled to the PCI bus for  
data transmission thereon. The transmission compatible apparatus comprises at least a  
high-bit transmitting buffer, a low-bit transmitting buffer, a multiplexer, and a strobe  
20 generator. The reception compatible apparatus comprises at least a data distributor.

[0011] The high-bit transmitting buffer is used to receive and temporarily store a  
high-bit data. Similarly, the low-bit transmitting buffer is used to receive and  
temporarily store a low-bit data. The multiplexer is coupled to the high-bit and low-bit  
transmitting buffers to receive a first internal bus clock signal. When the first internal

bus clock signal is at a high potential level, the multiplexer selects the output of either the high-bit or the low-bit transmitting buffer to output to the PCI bus. When the first internal bus clock signal is at a low potential level, the multiplexer selects the output of the other either the high-bit or the low-bit transmitting buffer to output to the PCI bus.

- 5 When the transmission compatible apparatus outputs data to the PCI bus, the strobe generator generates the data strobe signal from either the bus grant signal pin or the bus request signal pin in response to the first internal bus clock signal. The data distributor of the reception compatible apparatus receives data from the PCI bus according to the data strobe signal, and outputs the received high-bit data and the received low-bit data,
- 10 respectively.

[0012] In a further embodiment, when the transmission compatible apparatus is applied to the bus master and the reception compatible apparatus is applied to the bus bridge, the bus request signal pin transmits the data strobe signal when the bus master outputs data to the PCI bus. When the reception compatible apparatus is applied to the bus master and the transmission compatible apparatus is applied to the bus bridge, the bus grant signal pin is used to receive the data strobe signal when the bus masters receives data from the PCI bus. The above bus bridge arbitrates the master control of the PCI bus according to the bus request signal and the bus grant signal.

[0013] The invention uses data strobe signal transmitted from the bus request signal pin and the bus grant signal pin and the rising and descending edges of the data strobe signal as a reference for transmission. Thus, the original PCI bus is compatible, and the original PCI clock can be used as the strobe for an operation with a dual data transmission speed.

The invention also discloses a method for transmitting data on a PCI bus in a

computer comprising a plurality of masters and a host bridge coupled to the PCI bus. The PCI bus comprises a plurality of bus request signals and a plurality of bus grant signals. BIOS detects whether the masters supports a dual transmission mode while starting up the computer. BIOS also compares the vendor's IDs and the device IDs of  
5 the masters with a status list to determine whether the masters support the dual transmission mode. The masters with the dual transmission mode assert the corresponding bus request signal to response the computer. Therefore, BIOS is capable of programming a host bridge in response to the masters supporting the dual transmission mode. When the dual transmission mode is required, a dual mode ID is asserted to activate the dual transmission mode. The host bridge grants the PCI bus to one of the masters supporting the dual transmission mode and a dual mode ID is asserted. If a range of a memory space supporting the dual transmission mode is accessed. perform the memory access at a dual speed, otherwise perform the memory access at a normal speed. [0014] Both the foregoing general description and the  
10 following detailed description are exemplary and explanatory only and are not  
15 restrictive of the invention, as claimed.

#### BRIEF DESCRIPTION OF THE DRAWINGS

[0015] Figure 1 is a block diagram showing a conventional PCI bus;

20 [0016] Figure 2 is a block diagram showing a PCI bus structure that supports a dual data transmission speed according to one embodiment of the invention;

[0017] Figure 3 shows the timing sequence of a PCI bus structure that supports a dual data transmission speed according to one embodiment of the invention;

[0018] Figure 4 is a block diagram showing the data distributor of a PCI bus

compatible apparatus with a dual transmission mode according to one embodiment of the invention;

Figure 5 shows an exemplary circuit for the data distributor in Figure 4; and

[0019] Figure 6 shows the timing sequence of the PCI bus compatible apparatus

5 in Figure 4 and Figure 5.

#### DESCRIPTION OF THE PREFERRED EMBODIMENTS

[0020] The theory and method of the invention incorporate the major techniques disclosed in the Taiwanese patent application no. 88103699, with US corresponding application No. 09/447,724. The mentioned application discloses the system and method of data transmission on the PCI bus, and the invention further discloses the implemented apparatus and bus structure thereof.

[0021] Figure 2 illustrates a block diagram showing the transmission status of a PCI bus structure that supports a dual transmission mode. The embodiment includes a master 54 and a host bridge 52 with a dual transmission mode function, and masters 56/58 which are compatible with normal PCI structure. These apparatuses can be operated normally with the original PCI bus system.

[0022] In Figure 2, only the PCI master 54 can support the dual transmission mode. In fact, the dual transmission mode is applied only when the master 54 and the host bridge 52 both with the dual transmission mode are performing write and read operations on AD bus. For others such as the masters 54/56/58 and the transmission between them, or the command output from the host bridge 52 and the transmission with the masters 54/56/58, the original PCI compatible control clock is used in data transmission to ensure the completeness of the data.

[0023] When the computer system is just booted, whether the host bridge 52 comprises a dual transmission function is detected. If yes, whether the master 54, the master 56 and the master 58 support the dual transmission mode is judged. For example, the BIOS of the system itemizes all the vendor IDs and the device IDs that can support dual transmission mode as a status list. The system compares whether the masters 54, 56 and 58 are one of the above to support the dual transmission mode. This is because the specification of the standard PCI bus does not have any special ID to support the dual transmission mode. Alternatively, a predetermined address of a configured space is queried. If any of the masters supports dual transmission mode, all the master(s) supporting the dual transmission mode enable their request signals (REQ). The request signal(s) of all the master(s) are reported to the system via the host bridge 52 to confirm the master(s) supporting the dual transmission mode in response to the request signal(s). The result is stored in the system. The BOIS, for example, programs the host bridge 52 according to the result, such that the host bridge 52 can distinguish which request/grant signal pair supports the dual transmission mode.

[0024] In this embodiment, as shown in Fig. 2, only the PCI master 54 can support the dual transmission mode. While the host bridge 52 grants the master 54 with the dual transmission mode and the host bridge 52 intends to operate in the dual transmission mode, the master 54 with the dual transmission mode asserts a plurality of distinguishable bytes at the AD bus. For example, the lowest two bits of the address signal[1:0] are configured as 2 to advise the host bridge 52 entering the dual transmission mode. When the host bridge 52 grants the master 54 with the dual transmission mode to use the bus, and receives the address signal of the bus command that has lowest two bits equal to 2, the host bridge 52 enters the dual transmission mode.

The BIOS informs the master 54 with the dual transmission mode about an address range, such as in the system memory, that supports the dual transmission mode. When the transaction is within the address range that supports the dual transmission mode, the host bridge 52 and the master 54 are both allowed to enter the dual transmission mode.

- 5 In addition, the lowest two bits of the address signals[1:0] can also be configured as a value 0, for example, other than 2, thus the bus transactions can be configured to perform in a normal mode.

[0025] In Figure 3, a timing sequence of the PCI bus structure that supports the dual transmission mode according to the present invention is shown. When the PCI bus starts transmitting data on the AD bus (such as the data signals D0/D1/D2/D3/D4/D5/D6/D7/D8/D9), the transmission strobe signal the REQ signal, is used to latch the data. In the data cycle, the transmission of AD bus signals D0/D1 to the PCI bus is started. However, the ready signal TRDY# for the selected host bridge is not ready yet. Thus, the master 54 resends the data D0/D1. Accordingly, by generating proper wait states, the transmission of data D4/D5 and D8/D9 are transferred in a similar way.

[0026] The frame signal FRAME# deasserts at the last data D8/D9 to inform the selected host bridge that D8/D9 are the last data to be transmitted. In the second transmission of the data D8/D9, a stop signal STOP# is asserted to finish the transmission operation.

[0027] In Figure 4, a block diagram of a PCI compatible apparatuswith the dual transmission mode according to the present invention is illustrated. The PCI bus structure comprises a master 54 and a host bridge both having the dual transmission mode. Each of the master 54 and the host bridge 52 comprises a transmission

compatible apparatus and a reception compatible apparatus which both support the dual transmission mode. The transmission compatible apparatuses and the reception compatible apparatuses are correspondingly coupled to each other via the PCI bus 70. For example, the transmission compatible apparatus 55 of the master 54 is 5 correspondingly connected with the reception compatible apparatus 57 via the PCI bus 70 to write data into the memory (not shown) connected to the host bridge 52. Meanwhile, the bus request signal REQ is used to transmit the data strobe signal. Similarly, the transmission compatible apparatus (not indicated) of the host bridge 52 is correspondingly connected to the reception compatible apparatus (not indicated) of the master 54 via the PCI bus 70. When the master 54 receives the data from the PCI bus 10 70 to read the memory data via the host bridge 52, the bus grant signal GNT is asserted to receive the data strobe signal.

[0028] The first-in-first-out (FIFO) memory 62 is coupled to the high-bit transmitting buffer  $ADH_{OUT}$  and the low-bit transmitting buffer  $ADL_{OUT}$  to receive a 15 plurality of transmission data. FIFO 62 transfers the high-bit and low-bit data to the high-bit and low-bit transmitting buffers  $ADH_{OUT}$  and  $ADL_{OUT}$ , respectively.  $ADL_{OUT}$  and  $ADH_{OUT}$  of the data buffer pair 64 respectively receive the AD bus according to the transmission sequence of AD bus. The received data is then transmitted as the high-bit transmitting data and the low-bit transmitting data to the multiplexer 66. The 20 multiplexer 66 transmits the AD data to the PCI bus 70 according to the high potential level and the low potential level (or the rising and falling edges) of the bus clock signal  $PCICLK_T$ .

[0029] The PCI bus 70 transmits the AD bus to the data distributor 72. Meanwhile, the bus clock signal  $PCICLK_T$  is transmitted to the data distributor 72 by

the strobe generator 68, which for example is a request signal apparatus 68 to utilize the REQ signal to generate the proper strobe signal according to the bus clock signal PCICLK<sub>R</sub>. That is, the transmission pin of the REQ signal is used as the pin of the data strobe signal to transmit the data strobe signal with the same frequency as the bus clock signal. The same frequency of the data, the data strobe signal output from the transmission line of the strobe generator 68 is delayed while arriving the host bridge 52.

[0030] According to the data strobe signal coming from the strobe generator 68 and the received bus clock signal PCICLK<sub>R</sub>, the data distributor 72 is capable of partitioning the received the AD bus signals. The data distributor 72 transmits the AD bus to the receiving low-bit buffer ADL<sub>in</sub> and the receiving high-bit buffer ADH<sub>in</sub> of the data buffer pair 74. The bus clock signal PCICLK<sub>R</sub> for the data distributor 72 is used to synchronize the received AD bus while transferring internally.

[0031] Figure 5 shows a block diagram of the data distributor 72 of the PCI bus compatible apparatus with the dual transmission mode in Figure 4. Referring to Figures 4 and 5, the AD bus signals received by the buffer 80 from the PCI bus 70 is output to an output controller 84/86. The output controllers 84 and 86 are also called the trigger latch 86 and the negative enable latch 84, wherein a D-type flip-flop is used as the output controller in this embodiment as an example. Each of the output controllers 84 and 86 comprises a data input terminal, a trigger terminal and a data output terminal. The data input terminal is coupled to the output of the data buffer 80. The trigger terminal is coupled to the output of the strobe signal buffer 82 to latch the high-bit data, indicated as pre ADH<sub>in</sub>, and the low-bit data, indicated as pre ADL<sub>in</sub>, according to the received data strobe signal, which is the REQ signal in this embodiment.

[0032] The data input terminal of the trigger latch 88 is coupled to the data

output terminal of the negative enable latch 84. The trigger terminal is coupled to the internal bus clock signal PCICLK<sub>R</sub> to cause the data of the data input terminal output to the data output terminal, that is, output of the received low-bit data, to be synchronous to the internal bus clock signal PCICLK<sub>R</sub>. Similarly, the data input terminal of the  
5 negative enable latch 90 is coupled to the data output terminal of the trigger latch 86. The trigger terminal of the negative enable latch 86 is coupled to the internal bus clock signal to cause the data of the data input terminal output at the data output terminal, that is, output of the received high-bit data, to be synchronous to the internal bus clock signal PCICLK<sub>R</sub>. That is, the latches 88/90 output the pre ADL<sub>in</sub> and pre ADH<sub>in</sub> signals  
10 according to the bus clock signal PCICLK<sub>R</sub>, so as to transfer the data to the ADL<sub>in</sub> and ADH<sub>in</sub> of the data buffer pair 74 respectively.

[0033] In Figure 5, the data input terminal of the trigger latch 88 is coupled to the data output terminal of the negative enable latch 84, while the data input terminal of the negative enable latch 90 is coupled to the data output terminal of the trigger latch 86.

15 Two sets of latches are used so as to synchronize the data with the internal bus clock signal PCICLK<sub>R</sub>. Therefore, one can also couple the data input terminal of the negative enable latch 90 to the data output terminal of the negative enable latch 84, and the data input terminal of the trigger latch 88 to the data output terminal of the trigger latch 86.

[0034] Figure 6 shows the timing sequence of the PCI compatible apparatus  
20 illustrated in Figures 4 and 5. Referring to Figures 6, 5 and 4, the AD bus signals L0 and H0, for example, are sequentially stored in the first-in-first-out memory 62, and respectively output to the ADL<sub>OUT</sub> and ADH<sub>OUT</sub> of the data buffer pair 64 and the multiplexer 66.

[0035] The multiplexer 66 sends the AD bus signals L0 and H0 to the PCI bus

70 according to the low and high potential levels of the bus clock signal PCICLK<sub>T</sub>. Meanwhile, via the strobe generator 68, the signal PCICLK<sub>T</sub> outputs the data strobe signal REQ<sub>OUT</sub> from the request signal pin REQ. Being delayed by the PCI bus 70, the PCICLK<sub>T</sub> is further sent to the data distributor 72 using the REQ<sub>IN</sub>. In Figure 6,  
5 according to the data strobe signal, which is generated in response to the PCICLK<sub>T</sub> signal, and the bus clock signal PCICLK<sub>R</sub>, the data distributor 72 outputs the AD bus signals L0 and H0 to the ADL<sub>in</sub> and ADH<sub>in</sub> of the data buffer pair 74, respectively. The PCICLK<sub>T</sub> signal includes the data strobe signal in this embodiment. The rest of the AD bus signals are transmitted in a similar way.

10 [0036] Figure 6 and Figure 5 discloses that the master 54 outputs data to the PCI bus by utilizing the bus request signal pin REQ transmitting the data strobe signal. Similarly, it can be inferred by people of ordinary skilled in the art, in view of the above disclosure, that applying the bus grant signal pin GNT receives the data strobe signal when the host bridge 52 is outputting data to the PCI bus, and the master 54 is receiving  
15 data on the PCI bus.

[0037] Other embodiments of the invention will appear to those skilled in the art from consideration of the specification and practice of the invention disclosed herein. It is intended that the specification and examples be considered as exemplary only, with a true scope and spirit of the invention being indicated by the following claims.